<script lang="ts" setup>
import { userAdd } from '@/api/consumer';
import { useLockFn } from '@/hooks/useLockFn';
import { ElMessage, type FormInstance, type FormRules } from 'element-plus';

interface DetailType {
  avatar: string;
  create_time: string;
  name: string;
  sn: string;
  id: string;
  disable: number;
  tel: string;
  tactics: number;
  domain_alias: string;
  domain_alias_enable: number;
  notes: string;
  account: string;
  password: string;
  password_confirm: string;
}

const emits = defineEmits(['refresh']);
const drawer = ref<boolean>(false);
const formRef = shallowRef<FormInstance>();
const submited = ref<boolean>(false);
const formData = ref<DetailType>({
  avatar: '',
  create_time: '',
  name: '',
  sn: '',
  id: '',
  disable: 0,
  tel: '',
  tactics: 0,
  domain_alias: '',
  domain_alias_enable: 1,
  notes: '',
  account: '',
  password: '',
  password_confirm: '',
});

const rules: FormRules = {
  name: [
    {
      required: true,
      message: '请输入租户名称',
      trigger: ['blur'],
    },
  ],
  disable: [
    {
      required: true,
      message: '请选择租户状态',
      trigger: ['blur'],
    },
  ],
  tactics: [
    {
      required: true,
      message: '请选择分表策略',
      trigger: ['blur'],
    },
  ],
};

const openHandle = () => {
  submited.value = false;
  drawer.value = true;
};

const beforeClose = (done: () => void) => {
  if (submited.value) done();
  ElMessageBox.confirm('表单未提交，确认退出编辑吗？')
    .then(() => {
      done();
    })
    .catch(() => {});
};

const afterClose = () => {
  formRef.value?.resetFields();
};

const submitAdd = async () => {
  await formRef.value?.validate();
  if (formData.value.password !== formData.value.password_confirm) {
    return ElMessage.error('两次密码输入不一致');
  }
  await userAdd(formData.value);
  submited.value = true;
  drawer.value = false;
  emits('refresh');
};

const { isLock, lockFn: lockSubmit } = useLockFn(submitAdd);

defineExpose({
  openHandle,
});
</script>

<template>
  <el-drawer
    v-model="drawer"
    title="新增租户"
    direction="rtl"
    size="50%"
    :destroy-on-close="true"
    :before-close="beforeClose"
    @close="afterClose"
  >
    <el-form
      ref="formRef"
      class="ls-form"
      label-position="right"
      :model="formData"
      :rules="rules"
      label-width="100px"
    >
      <div class="form_header">基础信息</div>
      <el-form-item label="头像：" prop="avatar">
        <material-picker v-model="formData.avatar" :limit="1" />
      </el-form-item>
      <el-form-item label="租户名称：" prop="name">
        <el-input v-model="formData.name" placeholder="请输入租户名称" style="width: 280px" />
      </el-form-item>
      <el-form-item label="租户状态：" prop="disable">
        <el-radio-group v-model="formData.disable">
          <el-radio :value="0">开启</el-radio>
          <el-radio :value="1">关闭</el-radio>
        </el-radio-group>
      </el-form-item>
      <el-form-item label="联系方式：" prop="tel">
        <el-input
          v-model="formData.tel"
          :maxlength="30"
          placeholder="请输入联系方式"
          style="max-width: 250px"
        />
      </el-form-item>
      <el-form-item label="分表策略：" prop="tactics">
        <el-radio-group v-model="formData.tactics">
          <el-radio :value="0">公表模式</el-radio>
          <el-radio :value="1">分表模式</el-radio>
        </el-radio-group>
      </el-form-item>
      <el-form-item label="域名别名：" prop="domain_alias">
        <el-input
          v-model="formData.domain_alias"
          placeholder="请输入域名别名"
          style="max-width: 250px"
        />
      </el-form-item>
      <el-form-item label="启用别名：" prop="domain_alias_enable">
        <div>
          <el-radio-group v-model="formData.domain_alias_enable">
            <el-radio :value="0">启用</el-radio>
            <el-radio :value="1">禁用</el-radio>
          </el-radio-group>
          <p class="text-info text-sm">
            Tips：项目线上部署后，配置好域名别名并解析到默认域名后启用即可生效
          </p>
        </div>
      </el-form-item>
      <el-form-item label="租户备注：" prop="notes">
        <el-input
          v-model="formData.notes"
          placeholder="请输入租户备注"
          style="max-width: 250px"
          type="textarea"
          :maxlength="100"
        />
      </el-form-item>
      <div class="form_header">
        账号信息
        <span class="text-info text-xs font-normal opacity-70">
          （不填则生成默认账号，账号默认为sn编码，密码默认123456）
        </span>
      </div>
      <el-form-item label="管理员账号：" prop="account">
        <el-input
          v-model="formData.account"
          placeholder="请输入管理员账号"
          style="max-width: 250px"
        />
      </el-form-item>
      <el-form-item label="密码：" prop="password">
        <el-input
          v-model="formData.password"
          type="password"
          placeholder="请输入密码"
          style="max-width: 250px"
        />
      </el-form-item>
      <el-form-item label="确认密码：" prop="password_confirm">
        <el-input
          v-model="formData.password_confirm"
          type="password"
          placeholder="请再次输入密码"
          style="max-width: 250px"
        />
      </el-form-item>
      <el-form-item>
        <el-button type="primary" :loading="isLock" @click="lockSubmit">提交</el-button>
      </el-form-item>
    </el-form>
  </el-drawer>
</template>

<style lang="scss" scoped>
.form_header {
  @apply mb-4 rounded p-2 text-lg font-bold;
  background-color: rgba(204, 204, 204, 0.2);
}
</style>
